
<!DOCTYPE html>
<html lang="en-us">
<head>
  
  <meta charset="UTF-8" />
  <meta name="description" content="gRPC是一个高性能、通用的开源RPC框架，该框架已广泛应用于Google的云产品和谷歌的对外提供的API服务中。gRPC由Google主要面向移动应用开发并基于HTTP/2协议标准而设计，基于ProtoBuf(Protocol Buffers)序列化协议开发，且支持众多开发语言。" />
  <title>
    gRPC：Google开源的基于HTTP/2和ProtoBuf的通用RPC框架 | DenysG的个人博客
  </title>
  
  <meta name="viewport" content="width=device-width,user-scalable=no,maximum-scale=1,initial-scale=1">
  
  <link rel="canonical" href="https://48474.net/post/grpc-google-http2-protobuf/"/>
  <link rel="shortcut icon" type="image/x-icon" href="/favicon.ico">
  
  <link rel="stylesheet" href="/css/sanitize.css">
  <link rel="stylesheet" href="/css/responsive.css">
  <link rel="stylesheet" href="/css/highlight_monokai.css">
  <link rel="stylesheet" href="/css/theme.css">
  <link rel="stylesheet" href="/css/custom.css">
  
  
  <link href="https://48474.net//index.xml" rel="alternate" type="application/rss+xml" title="DenysG的个人博客" />
  <link href="https://48474.net//index.xml" rel="feed" type="application/rss+xml" title="DenysG的个人博客" />

  
  

</head>



<body>
<div class="container">
  
  <header role="banner">
    <div class="row gutters">
      <div id="site-title" class="col span_6">
        <h1><a href="https://48474.net/">DenysG的个人博客</a></h1>
        <h2>我必须承认，幸运喜欢照顾勇敢的人。---- 达尔文</h2>
      </div>
      <div id="social" class="col span_6">
        <ul>
          
          
          <li><a href="https://github.com/cnphpbb/" target="_blank">GitHub</a></li>
          
        </ul>
      </div>
    </div>
  </header>


  
  <main id="single" role="main">
    <div class="article-header">
      <h1>gRPC：Google开源的基于HTTP/2和ProtoBuf的通用RPC框架</h1>
      <div class="meta">
        Aug 15, 2018 &nbsp;
        
          #<a href="/tags/grpc">gRPC</a>&nbsp;
        
          #<a href="/tags/guide">guide</a>&nbsp;
        
          #<a href="/tags/solutions">solutions</a>&nbsp;
        
          #<a href="/tags/golang">golang</a>&nbsp;
        
          #<a href="/tags/rpc%E6%A1%86%E6%9E%B6">RPC框架</a>&nbsp;
        
          #<a href="/tags/%E5%BC%80%E6%BA%90">开源</a>&nbsp;
        
      </div>
    </div>
    <article>
      <p><a href="https://github.com/grpc/">gRPC</a>是一个高性能、通用的开源RPC框架，其由Google主要面向移动应用开发并基于<a href="https://http2.github.io/">HTTP/2</a>协议标准而设计，基于<a href="http://en.wikipedia.org/wiki/Protocol_Buffers">ProtoBuf</a>(Protocol Buffers)序列化协议开发，且支持众多开发语言。gRPC提供了一种简单的方法来精确地定义服务和为iOS、Android和后台支持服务自动生成可靠性很强的客户端功能库。客户端充分利用高级流和链接功能，从而有助于节省带宽、降低的TCP链接次数、节省CPU使用、和电池寿命。</p>
<p>gRPC具有以下重要特征：</p>
<ul>
<li>
<p>强大的IDL特性</p>
<p>gRPC使用ProtoBuf来定义服务，ProtoBuf是由Google开发的一种数据序列化协议（类似于XML、JSON、hessian）。ProtoBuf能够将数据进行序列化，并广泛应用在数据存储、通信协议等方面。不过，当前gRPC仅支持 Protobuf ，且不支持在浏览器中使用。由于gRPC的设计能够支持支持多种数据格式，所以读者能够很容易实现对其他数据格式（如XML、JSON等）的支持。</p>
<p>定义服务的示例代码如下：</p>
<pre tabindex="0"><code>message HelloRequest {
  string greeting = 1;
}
message HelloResponse {
  string reply = 1;
}
service HelloService {
  rpc SayHello(HelloRequest) returns (HelloResponse);
}
</code></pre></li>
<li>
<p>支持多语言</p>
<p>gRPC支持多种语言，并能够基于语言自动生成客户端和服务端功能库。目前，在GitHub上已提供了 C版本<code>grpc</code>、Java版本<code>grpc-java</code> 和 Go版本<code>grpc-go</code>，其它语言的版本正在积极开发中，其中 grpc支持 <code>C</code>、<code>C++</code>、<code>Node.js</code>、<code>Python</code>、<code>Ruby</code>、<code>Objective-C</code>、<code>PHP</code> 和 <code>C#</code> 等语言，<code>grpc-java</code> 已经支持Android开发。</p>
</li>
<li>
<p>基于HTTP/2标准设计</p>
<p>由于gRPC基于HTTP/2标准设计，所以相对于其他RPC框架，gRPC带来了更多强大功能，如双向流、头部压缩、多复用请求等。这些功能给移动设备带来重大益处，如节省带宽、降低TCP链接次数、节省CPU使用和延长电池寿命等。同时，gRPC还能够提高了云端服务和Web应用的性能。gRPC既能够在客户端应用，也能够在服务器端应用，从而以透明的方式实现客户端和服务器端的通信和简化通信系统的构建。</p>
</li>
</ul>
<p>gRPC已经应用在Google的云服务和对外提供的API中，其主要应用场景如下：</p>
<ul>
<li>低延迟、高扩展性、分布式的系统</li>
<li>同云服务器进行通信的移动应用客户端</li>
<li>设计语言独立、高效、精确的新协议</li>
<li>便于各方面扩展的分层设计，如认证、负载均衡、日志记录、监控等</li>
</ul>
<p>近日，gRPC开发团队宣布gRPC基于 <a href="http://opensource.org/licenses/BSD-3-Clause/">BSD 3-Clause License</a> 许可协议开源，相关代码已托管在<a href="https://github.com/grpc">GitHub</a>上。当前已有Google和移动支付公司<a href="https://squareup.com">Square</a>以及其他组织或个人为该项目贡献代码。有兴趣的读者可以在GitHub选择需要的语言版本，并根据提供的README文档尝试gRPC的功能，或者参考FAQ，以获得对gRPC更多信息。此外，在<a href="https://github.com/grpc/grpc-common">gRPC-common</a>仓库中，还提供了例子、快速入门指南等相关文档。</p>

      
      
      
    </article>
    


  </main>
  
  <nav class="pagination-single">
    
      <span class="previous">&larr; <a href="https://48474.net/post/vps_debian_unremove_service/" rel="prev">VPS Debian8 删除一些没用的服务的方法</a></span>
    
    
      <span class="next"><a href="https://48474.net/post/dockerfile-reference-1/" rel="next">Dockerfile 参考文档 （一）</a> &rarr;</span>
    
  </nav>


  
  <footer role="contentinfo">
    <div style="text-align:center;">
      
      © 2020 135Get_Team. All rights reserved.
    </div>
  </footer>


</div>

<script src="/js/highlight.pack.js"></script>
<script>hljs.initHighlightingOnLoad();</script>



</body>
</html>

